草庐IT

MySQL Group by - 获取计数为零的列

全部标签

ruby - 对文件进行符号链接(symbolic link)后,如何在 Ruby 中获取原始文件的路径?

我有一个路径为/foo/bar/gazook/script.rb的Ruby脚本。我还在$HOME/bin中创建了指向它的符号链接(symboliclink)。现在,我希望我的Ruby脚本访问目录/foo中的一些其他文件,并保持路径相对,我有一个变量FOO_DIRECTORY=File.expand_path(File.dirname(__FILE__)+"/../../")在我的脚本中。问题是,如果我从它的符号链接(symboliclink)运行我的脚本,这个相对目录是错误的(因为我猜它是从不同的位置扩展的)。我该如何解决这个问题?除了使用绝对路径还有其他方法吗?

ruby - 尝试使用 nokogiri 获取 xml 文件中 cdata 标签内的内容

我已经看到了几件事,但到目前为止似乎没有任何效果。我正在使用nokogirionrails3ruby​​1.9.2通过url解析xml。xml的片段如下所示:我正在尝试解析它以获取与NewsLineText关联的文本r=node.at_xpath('.//newslinetext')ifnode.at_xpath('.//newslinetext')s=node.at_xpath('.//newslinetext').textifnode.at_xpath('.//newslinetext')t=node.at_xpath('.//newslinetext').contentifnod

ruby-on-rails - Rails - 如何获取访问者的IP地址?

我需要将访问者的IP地址存储到我们的数据库中,这是我尝试这样做的方式:@ip=request.remote_ip@ip=request.env['REMOTE_ADDR']但在这两种情况下,@ip变量都存储了值127.0.0.1,即使我将应用程序部署到AmazonEC2实例也是如此。当我检查http://www.whatismyip.com/时,它将我的IP显示为109.175.XXX.X。那么为什么ruby变量总是显示127.0.0.1地址呢?如何获取真实IP?编辑:这是以下内容的输出:request.env['HTTP_X_FORWARDED_FOR']=>request.remo

ruby-on-rails - ActiveRecord 关联选择包含记录的计数

例子classUserhas_many:ticketsend我想创建关联,其中包含用户计数票的逻辑,并在包含(用户has_oneticket_count)中使用它Users.includes(:tickets_count)我试过了has_one:tickets_count,:select=>"COUNT(*)astickets_count,tickets.user_id",:class_name=>'Ticket',:group=>"tickets.user_id",:readonly=>trueUser.includes(:tickets_count)ArgumentError:Un

ruby - XPath 轴,获取所有后续节点直到

我有以下HTML示例:FoobarloremipsumetcBarbazdumdumdumpoopfiddles我希望提取“Foobar”标题后的所有段落,直到到达“Barbaz”标题(“Barbaz”标题的文本未知,所以很遗憾我无法使用答案由bougyman提供)。现在我当然可以使用//h2[text()='Foobar']/following::p之类的东西,但这当然会抓取此后的所有段落header。因此,我可以选择遍历节点集并将段落插入数组,直到文本与下一个header的文本相匹配,但老实说,这远不如在XPath中完成这件事那么酷。有没有办法做到这一点我想念的?

ruby-on-rails - 在 Rails 上获取模型或 404

是否可以在Rails上使用get_by_id_or_404函数。例如,在我的Controller中我使用:@destination=Destination.find_by_id(params[:id])如果未设置ID或未找到目的地,我如何让Rails重定向到404页面?谢谢! 最佳答案 在生产模式下,Rails通过呈现404错误页面自动挽救ActiveRecord::RecordNotFound异常。当没有找到结果时,只需使用引发ActiveRecord::RecordNotFound的finder的bang版本。@destinat

ruby - 计数 Ruby 1.8.6 中数组中值的实例

以下行在ruby​​1.8.7中运行良好,但在1.8.6中运行不正常。我可以在1.8.6中使用什么替代方案x=[3,4,5,6,7,78,4,3,2,5,5,3]x.count(3)=>3由于在1.8.6版本中count不是Array中的方法,因此我收到此错误。这个版本有没有类似的方法? 最佳答案 x=[3,4,5,6,7,78,4,3,2,5,5,3]x.grep(3).size#=>3 关于ruby-计数Ruby1.8.6中数组中值的实例,我们在StackOverflow上找到一个类

ruby - ActiveRecord - 获取最后 n 条记录并在一个命令中删除它们?

大家好,感谢您花时间回答我的问题。题中确实解释了这个问题。我尝试了Model.last(n).destroy_all但都不起作用。我想知道是否可以在一行中完成,如果不能,最简洁的方法是什么?再次感谢! 最佳答案 要在一个SQL查询中执行此操作,请使用delete_all:Model.order(created_at::desc).limit(n).delete_all但是delete_all不会执行任何模型回调或验证要运行回调和验证,请使用destroy_all:Model.order(created_at::desc).limit

ruby-on-rails - 如何覆盖 Rails 模型中的列?

我有一个数据库表的模型。我想覆盖该特定表的列名。我将如何实现它。例如,假设我的表名为DUMMY,其中有一列名为col_acol_a2034422312我会做一个@dummy.col_a。现在,对于以0结尾的数字,此方法应返回0,对于其他所有内容,它应返回原始值。我可以通过定义一个新方法来做到这一点,但我想覆盖列名本身。请帮忙。 最佳答案 您可以覆盖col_a方法。使用read_attribute方法读取数据库中的值。像这样:defcol_aifself.read_attribute(:col_a).to_s.end_with?('0

Ruby:获取本地 IP (nix)

我需要获取我的IP(即DHCP)。我在我的environment.rb中使用它:LOCAL_IP=`ifconfigwlan0`.match(/inetaddr:(\d*\.\d*\.\d*\.\d*)/)[1]||"localhost"但是有没有ruby​​way或更干净的解决方案? 最佳答案 服务器通常有多个接口(interface),至少一个私有(private)接口(interface)和一个公共(public)接口(interface)。因为这里的所有答案都是针对这个简单的场景,一个更简洁的方法是向Socket询问当前的i